new ParseGroup( "domain", domaincommands ),
new ParseGroup( "partitions", partitioncommands ),
new ParseGroup( "physical", physicalcommands ),
+ new ParseScript(),
new ParseGroup( "vd", vdcommands ),
new ParseGroup( "vbd", vbdcommands )
};
/** The top-level parser. */
static final CommandParser parser = new ParseGroup( null, commands );
+ public static void executeArgList (Defaults d, LinkedList arglist)
+ throws ParseFailedException, CommandFailedException
+ {
+ if (arglist.size() == 0) {
+ help.parse(null, null);
+ } else {
+ parser.parse(d, arglist);
+ }
+ }
+
public static void main(String[] args) {
Defaults d = new Defaults();
int ec = -1;
arglist.add( args[i] );
}
- if (args.length == 0) {
+ try {
+ executeArgList (d, arglist);
+ ec = 0;
+ } catch (NoSuchElementException e) {
help.parse(null, null);
- } else {
- try
- {
- parser.parse(d, arglist);
- ec = 0;
- } catch (NoSuchElementException e) {
- help.parse(null, null);
- } catch (ParseFailedException e) {
- System.err.println( e.getMessage() );
- } catch (CommandFailedException e) {
- System.err.println( e.getMessage() );
- }
+ } catch (ParseFailedException e) {
+ System.err.println( e.getMessage() );
+ } catch (CommandFailedException e) {
+ System.err.println( e.getMessage() );
}
System.exit(ec);
public class ParseDomainDestroy extends CommandParser {
public void parse(Defaults d, LinkedList args)
throws ParseFailedException, CommandFailedException {
- int domain_id = getIntParameter(args, 'n', 0);
+ int domain_id = getIntParameter(args, 'n', d.domainNumber);
boolean force = getFlagParameter(args, 'f');
if (domain_id == 0) {
}
public String getUsage() {
- return "-n<domain_id> [-f]";
+ return "[-n<domain_id>] [-f]";
}
public String getHelpText() {
public class ParseDomainStart extends CommandParser {
public void parse(Defaults d, LinkedList args)
throws ParseFailedException, CommandFailedException {
- int domain_id = getIntParameter(args, 'n', 0);
+ int domain_id = getIntParameter(args, 'n', d.domainNumber);
if (domain_id == 0) {
throw new ParseFailedException("Expected -n<domain_id>");
}
public String getUsage() {
- return "-n<domain_id>";
+ return "[-n<domain_id>]";
}
public String getHelpText() {
public class ParseDomainStop extends CommandParser {
public void parse(Defaults d, LinkedList args)
throws ParseFailedException, CommandFailedException {
- int domain_id = getIntParameter(args, 'n', 0);
+ int domain_id = getIntParameter(args, 'n', d.domainNumber);
if (domain_id == 0) {
throw new ParseFailedException("Expected -n<domain_id>");
}
public String getUsage() {
- return "-n<domain_id>";
+ return "[-n<domain_id>]";
}
public String getHelpText() {
public class ParsePhysicalGrant extends CommandParser {
public void parse(Defaults d, LinkedList args)
throws ParseFailedException, CommandFailedException {
- int domain_id = getIntParameter(args, 'n', 0);
+ int domain_id = getIntParameter(args, 'n', d.domainNumber);
boolean force = getFlagParameter(args, 'f');
String partition_name = getStringParameter(args, 'p', "");
boolean write = getFlagParameter(args, 'w');
}
public String getUsage() {
- return "-n<domain_id> -p<partition_name> [-f] [-w]";
+ return "-p<partition_name> [-n<domain_id>] [-f] [-w]";
}
public String getHelpText() {
public class ParsePhysicalList extends CommandParser {
public void parse(Defaults d, LinkedList args)
throws ParseFailedException, CommandFailedException {
- int domain_id = getIntParameter(args, 'n', 0);
+ int domain_id = getIntParameter(args, 'n', d.domainNumber);
if (domain_id == 0) {
throw new ParseFailedException("Expected -n<domain_id>");
}
public class ParsePhysicalRevoke extends CommandParser {
public void parse(Defaults d, LinkedList args)
throws ParseFailedException, CommandFailedException {
- int domain_id = getIntParameter(args, 'n', 0);
+ int domain_id = getIntParameter(args, 'n', d.domainNumber);
String partition_name = getStringParameter(args, 'p', "");
if (domain_id == 0) {
}
public String getUsage() {
- return "-n<domain_id> -p<partition_name>";
+ return "-p<partition_name> [-n<domain_id>]";
}
public String getHelpText() {
throws ParseFailedException, CommandFailedException {
String vd_key = getStringParameter(args, 'k', "");
String partition_name = getStringParameter(args, 'p', "");
- int domain_id = getIntParameter(args, 'n', 0);
+ int domain_id = getIntParameter(args, 'n', d.domainNumber);
int vbd_num = getIntParameter(args, 'v', -1);
boolean write = getFlagParameter(args, 'w');
}
public String getUsage() {
- return "-n<domain_id> {-k<key>|-p<partition} -v<vbd_num> [-w]";
+ return "{-k<key>|-p<partition} -v<vbd_num> [-n<domain_id>] [-w]";
}
public String getHelpText() {
domain_id = Integer.parseInt(br.readLine());
create_rc = create_p.waitFor();
}
+ d.domainNumber = domain_id;
if (create_rc != 0) {
throw CommandFailedException.xiCommandFailed(
public String args = "";
/** Directory to find XI tools. */
public String xiToolsDir = "";
+ /** Domain number */
+ public int domainNumber;
/**
domainImage = s;
} else if (lastName.equals("domain_name")) {
domainName = s;
+ } else if (lastName.equals("domain_number")) {
+ domainNumber = Integer.parseInt(s);
} else if (lastName.equals("domain_init_rd")) {
domainInitRD = s;
} else if (lastName.equals("domain_vifs")) {
/** Path to search for the defaults file. */
public static final String DEFAULTS_PATH =
System.getProperty("DEFAULTS_PATH", ".:/etc:/var/lib/xen");
- /** IP address of domain 0. */
- public static final String LOCAL_IP = System.getProperty("LOCAL_IP");
- /** Network mask of domain 0. */
- public static final String LOCAL_MASK = System.getProperty("LOCAL_MASK");
- /** Gateway of domain 0. */
- public static final String LOCAL_GW = System.getProperty("LOCAL_ROUTE");
/** If set, do not call any xi_ commands, just print their command lines. */
public static final boolean TEST = (System.getProperty("TEST") != null);
/** Name of xi_helper utility. */
if [ -z "$ROUTE" ] ; then ROUTE=/sbin/route ; fi
if [ -z "$JAVA" ] ; then JAVA=java ; fi
-if [ "$1" = "domain" -a "$2" = "new" ] ; then
- if [ ! -x "$IFCONFIG" ]; then
- echo Could not find executable $IFCONFIG
- exit 1
- fi
-
- if [ ! -x "$ROUTE" ]; then
- echo Could not find executable $ROUTE
- exit 1
- fi
-
- # Try to determine dom0 network settings to avoid hard-coding
- # particular machines in the defaults file
- LOCAL_IP=$(/sbin/ifconfig $QUERY_DEV | grep 'inet addr' | tr ':' '\t' | awk '{print $3}')
- LOCAL_MASK=$(/sbin/ifconfig $QUERY_DEV | grep 'Mask' | tr ':' '\t' | awk '{print $7}')
- LOCAL_ROUTE=$(/sbin/route -n | grep $QUERY_DEV | grep 'G' | awk '{print $2}')
-fi
-
-
-#ARGS="-DTEST -DDEFAULTS_FILE=$DEFAULTS_FILE -DDEFAULTS_PATH=$DEFAULTS_PATH -DLOCAL_IP=$LOCAL_IP -DLOCAL_MASK=$LOCAL_MASK -DLOCAL_ROUTE=$LOCAL_ROUTE"
-ARGS="-DDEFAULTS_FILE=$DEFAULTS_FILE -DDEFAULTS_PATH=$DEFAULTS_PATH -DLOCAL_IP=$LOCAL_IP -DLOCAL_MASK=$LOCAL_MASK -DLOCAL_ROUTE=$LOCAL_ROUTE"
+ARGS="-DDEFAULTS_FILE=$DEFAULTS_FILE -DDEFAULTS_PATH=$DEFAULTS_PATH"
$JAVA $ARGS -jar $(dirname $0)/xenctl-cmdline.jar $*